前端CSSHTMLwebCSS 学习笔记(11):移动 Web 开发之 vw 适配与酷我音乐案例实践
woodfish01-vw适配方案
vw和vh基本使用
vw和vh是相对单位,相对视口尺寸计算结果
- vw:viewport width(1vw = 1/100视口宽度 )
- vh:viewport height ( 1vh = 1/100视口高度 )
vw布局
vw单位的尺寸 = px 单位数值 / ( 1/100 视口宽度 ) 
vh问题
vh是1/100视口高度,全面屏视口高度尺寸大,如果混用可能会导致盒子变形 
02-综合案例-酷我音乐

准备工作

| 12
 
 | <link rel="stylesheet" href="./iconfont/iconfont.css"><link rel="stylesheet" href="./css/index.css">
 
 | 
头部布局
| 12
 3
 4
 5
 
 | <header>
 <div class="left">left</div>
 <a href="#">下载APP</a>
 </header>
 
 | 
| 12
 3
 4
 5
 6
 7
 8
 9
 10
 11
 12
 13
 14
 15
 
 | body {background-color: #f9fafb;
 }
 
 @vw:3.75vw;
 
 
 header {
 display: flex;
 justify-content: space-between;
 align-items: center;
 padding: 0 (15 / @vw);
 height: (50 / @vw);
 background-color: #fff;
 }
 
 | 
头部内容
| 12
 3
 4
 5
 6
 7
 8
 9
 10
 11
 12
 13
 14
 15
 16
 17
 18
 19
 
 | header {
 .left {
 width: (235 / @vw);
 height: (50 / @vw);
 background-image: url(../assets/head.png);
 background-size: contain;
 background-repeat: no-repeat;
 }
 a {
 width: (80 / @vw);
 height: (30 / @vw);
 background-color: #ffe31b;
 border-radius: (15 / @vw);
 text-align: center;
 line-height: (30 / @vw);
 font-size: (14 / @vw);
 }
 }
 
 | 
搜索区域
| 12
 3
 4
 5
 6
 7
 
 | <div class="search">
 <div class="txt">
 <span class="iconfont icon-sousuo"></span>
 <span>搜索你想听的歌曲</span>
 </div>
 </div>
 
 | 
| 12
 3
 4
 5
 6
 7
 8
 9
 10
 11
 12
 13
 14
 15
 16
 17
 18
 
 | .search {
 padding: (10 / @vw) (15 / @vw);
 height: (52 / @vw);
 
 .txt {
 height: (32 / @vw);
 background-color: #f2f4f5;
 border-radius: (16 / @vw);
 text-align: center;
 line-height: (32 / @vw);
 color: #a1a4b3;
 font-size: (14 / @vw);
 .iconfont {
 font-size: (16 / @vw);
 }
 }
 }
 
 | 
banner 区域
| 12
 3
 4
 5
 6
 
 | <div class="banner">
 <ul>
 <li><a href="#"><img src="./assets/banner01.jpeg" alt=""></a></li>
 </ul>
 </div>
 
 | 
| 12
 3
 4
 5
 6
 7
 8
 9
 10
 11
 12
 13
 14
 15
 16
 17
 18
 19
 20
 
 | .banner {
 padding: 0 (15 / @vw);
 height: (108 / @vw);
 
 ul {
 li {
 width: (345 / @vw);
 height: (108 / @vw);
 img {
 width: 100%;
 height: 100%;
 
 
 object-fit: cover;
 border-radius: (5 / @vw);
 }
 }
 }
 }
 
 | 
标题公共样式
| 12
 3
 4
 5
 6
 7
 8
 
 | <div class="list">
 
 <div class="title">
 <h4>酷我排行榜</h4>
 <a href="#">更多<span class="iconfont icon-right"></span></a>
 </div>
 </div>
 
 | 
| 12
 3
 4
 5
 6
 7
 8
 9
 10
 11
 12
 13
 14
 15
 16
 17
 18
 19
 20
 
 | .list {
 margin-top: (20 / @vw);
 padding: 0 (15 / @vw);
 }
 
 
 .title {
 display: flex;
 justify-content: space-between;
 margin-bottom: (16 / @vw);
 line-height: (25 / @vw);
 h4 {
 font-size: (20 / @vw);
 }
 a {
 font-size: (12 / @vw);
 color: #a1a4b3;
 }
 }
 
 | 
排行榜内容
| 12
 3
 4
 5
 6
 7
 8
 9
 10
 11
 12
 13
 14
 15
 16
 17
 18
 19
 20
 21
 22
 23
 24
 25
 26
 27
 28
 29
 30
 31
 32
 
 | <div class="content">
 <ul>
 <li>
 <div class="pic"><img src="./assets/icon_rank_hot.png" alt=""></div>
 <div class="txt">
 <a href="#" class="more">酷我热歌榜<span class="iconfont icon-right"></span></a>
 <a href="#">1.樱花树下的约定(完整版) - 旺仔小乔</a>
 <a href="#">2.就让这大雨全都落下 - 容祖儿</a>
 <a href="#">3.缺氧 - 轩姨(相信光)</a>
 </div>
 </li>
 <li>
 <div class="pic"><img src="./assets/icon_rank_new.png" alt=""></div>
 <div class="txt">
 <a href="#" class="more">酷我新歌榜<span class="iconfont icon-right"></span></a>
 <a href="#">1.樱花树下的约定(完整版) - 旺仔小乔</a>
 <a href="#">2.就让这大雨全都落下 - 容祖儿</a>
 <a href="#">3.缺氧 - 轩姨(相信光)</a>
 </div>
 </li>
 <li>
 <div class="pic"><img src="./assets/icon_rank_rise.png" alt=""></div>
 <div class="txt">
 <a href="#" class="more">酷我飙升榜<span class="iconfont icon-right"></span></a>
 <a href="#">1.樱花树下的约定(完整版) - 旺仔小乔</a>
 <a href="#">2.就让这大雨全都落下 - 容祖儿</a>
 <a href="#">3.缺氧 - 轩姨(相信光)</a>
 </div>
 </li>
 </ul>
 </div>
 
 | 
| 12
 3
 4
 5
 6
 7
 8
 9
 10
 11
 12
 13
 14
 15
 16
 17
 18
 19
 20
 21
 22
 23
 24
 25
 26
 27
 28
 29
 30
 31
 32
 33
 34
 35
 36
 
 | .list {
 margin-top: (20 / @vw);
 padding: 0 (15 / @vw);
 li {
 display: flex;
 margin-bottom: (16 / @vw);
 height: (105 / @vw);
 background-color: #fff;
 border-radius: (10 / @vw);
 .pic {
 margin-right: (20 / @vw);
 img {
 width: (105 / @vw);
 height: (105 / @vw);
 border-radius: (10 / @vw);
 }
 }
 .txt {
 a {
 display: block;
 font-size: (12 / @vw);
 color: #a1a4b3;
 line-height: 1.8;
 }
 
 .more {
 font-size: (14 / @vw);
 color: #333;
 .iconfont {
 font-size: (16 / @vw);
 }
 }
 }
 }
 }
 
 | 
推荐歌单布局
| 12
 3
 4
 5
 6
 7
 8
 9
 10
 11
 12
 13
 14
 15
 16
 17
 18
 19
 
 | <div class="recommend">
 
 <div class="title">
 <h4>推荐歌单</h4>
 <a href="#">更多<span class="iconfont icon-right"></span></a>
 </div>
 
 <div class="content">
 <ul>
 <li>1</li>
 <li>1</li>
 <li>1</li>
 <li>1</li>
 <li>1</li>
 <li>1</li>
 </ul>
 </div>
 </div>
 
 | 
| 12
 3
 4
 5
 6
 7
 8
 9
 10
 11
 12
 13
 14
 15
 
 | .recommend {
 padding: 0 (15 / @vw);
 ul {
 display: flex;
 flex-wrap: wrap;
 justify-content: space-between;
 li {
 margin-bottom: (16 / @vw);
 width: (105 / @vw);
 height: (143 / @vw);
 background-color: pink;
 }
 }
 }
 
 | 
推荐歌单内容
| 12
 3
 4
 5
 6
 7
 8
 9
 10
 11
 12
 13
 14
 15
 16
 17
 18
 19
 20
 21
 22
 23
 24
 25
 26
 27
 28
 29
 30
 31
 32
 33
 34
 35
 36
 37
 38
 39
 40
 41
 42
 
 | <li><div class="pic">
 <img src="./assets/song01.jpeg" alt="">
 <div class="cover">18.2W</div>
 </div>
 <div class="txt">抖音嗨爆DJ!劲爆旋律萦绕双耳</div>
 </li>
 <li>
 <div class="pic">
 <img src="./assets/song02.jpeg" alt="">
 <div class="cover">18.2W</div>
 </div>
 <div class="txt">抖音嗨爆DJ!劲爆旋律萦绕双耳</div>
 </li>
 <li>
 <div class="pic">
 <img src="./assets/song03.jpeg" alt="">
 <div class="cover">18.2W</div>
 </div>
 <div class="txt">抖音嗨爆DJ!劲爆旋律萦绕双耳</div>
 </li>
 <li>
 <div class="pic">
 <img src="./assets/song02.jpeg" alt="">
 <div class="cover">18.2W</div>
 </div>
 <div class="txt">抖音嗨爆DJ!劲爆旋律萦绕双耳</div>
 </li>
 <li>
 <div class="pic">
 <img src="./assets/song03.jpeg" alt="">
 <div class="cover">18.2W</div>
 </div>
 <div class="txt">抖音嗨爆DJ!劲爆旋律萦绕双耳</div>
 </li>
 <li>
 <div class="pic">
 <img src="./assets/song01.jpeg" alt="">
 <div class="cover">18.2W</div>
 </div>
 <div class="txt">抖音嗨爆DJ!劲爆旋律萦绕双耳</div>
 </li>
 
 | 
| 12
 3
 4
 5
 6
 7
 8
 9
 10
 11
 12
 13
 14
 15
 16
 17
 18
 19
 20
 21
 22
 23
 24
 25
 26
 27
 28
 29
 
 | .pic {
 position: relative;
 width: (105 / @vw);
 height: (105 / @vw);
 img {
 width: 100%;
 height: 100%;
 object-fit: cover;
 border-radius: (10 / @vw);
 }
 .cover {
 position: absolute;
 left: 0;
 bottom: 0;
 width: (70 / @vw);
 height: (28 / @vw);
 background-color: rgba(0,0,0,0.8);
 border-radius: 0 (10 / @vw) 0 (10 / @vw);
 text-align: center;
 line-height: (28 / @vw);
 color: #fff;
 font-size: (14 / @vw);
 }
 }
 
 .txt {
 font-size: (14 / @vw);
 }
 
 | 
下载区域
| 12
 3
 4
 5
 6
 
 | <div class="download">
 <img src="./assets/logo.png" alt="">
 <p>安装酷我音乐 发现更多好音乐</p>
 <span class="iconfont icon-right"></span>
 </div>
 
 | 
| 12
 3
 4
 5
 6
 7
 8
 9
 10
 11
 12
 13
 14
 15
 16
 17
 18
 19
 20
 21
 22
 23
 24
 25
 26
 27
 28
 29
 30
 31
 32
 
 | .download {
 position: fixed;
 left: (15 / @vw);
 bottom: (30 / @vw);
 
 display: flex;
 align-items: center;
 padding: 0 (10 / @vw) 0 (15 / @vw);
 width: (345 / @vw);
 height: (45 / @vw);
 background-color: #fff;
 border-radius: (22 / @vw);
 img {
 margin-right: (10 / @vw);
 width: (36 / @vw);
 height: (36 / @vw);
 }
 p {
 flex: 1;
 font-size: (14 / @vw);
 }
 span {
 width: (32 / @vw);
 height: (32 / @vw);
 background-color: #f2f3f5;
 border-radius: 50%;
 text-align: center;
 line-height: (32 / @vw);
 font-size: (16 / @vw);
 }
 }
 
 | 
头部固定
| 12
 3
 4
 5
 6
 7
 8
 9
 10
 11
 12
 13
 14
 15
 16
 17
 18
 19
 20
 21
 22
 
 | header {
 position: fixed;
 left: 0;
 top: 0;
 display: flex;
 justify-content: space-between;
 align-items: center;
 padding: 0 (15 / @vw);
 
 width: 100%;
 height: (50 / @vw);
 background-color: #fff;
 }
 
 
 .search {
 
 margin-top: (50 / @vw);
 padding: (10 / @vw) (15 / @vw);
 height: (52 / @vw);
 }
 
 |